import { getHeroListAPI } from "../../api/index"
import Variable from "../../constants/index"
import { Hero } from "../../types/hero"
// pages/hero_search/hero_search.ts
Page({

    /**
     * 页面的初始数据
     */
    data: {
      heroList: [] as Hero[],
      word:'', //定义搜索字段 
      searchWordsList: [] as string[] // 搜索历史记录
    },
  
    delAll() {
        this.setData({
          searchWordsList: []
        }, () => {
           wx.removeStorageSync(Variable.SEARCH_WORD_KEY)
        })
      },
    // 删除关键字方法
  delWord(event: WechatMiniprogram.TouchEvent) {
    this.setData({
      searchWordsList: this.data.searchWordsList.filter(item => item !== event.mark?.word)
    }, () => {
      wx.setStorageSync(Variable.SEARCH_WORD_KEY, JSON.stringify(this.data.searchWordsList))
    })
  },
    // 点击搜索的方法
  toSearch(event: WechatMiniprogram.TouchEvent) {
    this.setData({
      word: event.mark?.word
    },() => {
       this.searchList() // 搜索结果
    })
  },
    async searchList() {
        // 搜索列表
        if (this.data.word) {
          // 同步到data中，写入本地缓存就可以了
          wx.showLoading({ title: '查询中' })
          // 接口调用
          this.setData({
            heroList: await getHeroListAPI({ q: this.data.word }),
            searchWordsList: [...new Set([this.data.word,...this.data.searchWordsList])]
          }, () => {
            // 此时认为更新完成 拿到最新的数据
            console.log(this.data.searchWordsList)
            wx.setStorageSync(Variable.SEARCH_WORD_KEY, JSON.stringify(this.data.searchWordsList))
            wx.hideLoading()
          })
        }else {
          this.setData({
            heroList: []
          })
        }
      },
    toDetail(event:  WechatMiniprogram.TouchEvent) {
      wx.navigateTo({
        url: `/pages/hero_detail/hero_detail?heroId=${event.mark?.heroId}`
      })
    },
  
    /**
     * 生命周期函数--监听页面加载
     */
    onLoad() {
  
    },
  
    /**
     * 生命周期函数--监听页面初次渲染完成
     */
    onReady() {
  
    },
  
    /**
     * 生命周期函数--监听页面显示
     */
    getHistoryList(){
        this.setData({
          searchWordsList:JSON.parse(wx.getStorageSync(Variable.SEARCH_WORD_KEY)||"[]") as string[]
        })
    },
    onShow() {
       // 获取缓存中的历史记录
       this.getHistoryList()
    },
  
    /**
     * 生命周期函数--监听页面隐藏
     */
    onHide() {
  
    },
  
    /**
     * 生命周期函数--监听页面卸载
     */
    onUnload() {
  
    },
  
    /**
     * 页面相关事件处理函数--监听用户下拉动作
     */
    onPullDownRefresh() {
  
    },
  
    /**
     * 页面上拉触底事件的处理函数
     */
    onReachBottom() {
  
    },
  
    /**
     * 用户点击右上角分享
     */
    onShareAppMessage() {
  
    }
  })